local theme = require("_oml.theme-daddy.theme.plugins.barbecue")

return {
  -- nice winbar can click on items to jump to them like VS****)
  "utilyre/barbecue.nvim",
  name = "barbecue",
  -- version = "*",
  dependencies = {
    "SmiteshP/nvim-navic",
    "nvim-tree/nvim-web-devicons", -- optional dependency
  },
  opts = {
    ---Whether to attach navic to language servers automatically.
    ---@type boolean
    attach_navic = true,

    ---Whether to create winbar updater autocmd.
    ---@type boolean
    create_autocmd = true,

    ---Buftypes to enable winbar in.
    ---@type string[]
    include_buftypes = { "" },

    ---Filetypes not to enable winbar in.
    ---@type string[]
    exclude_filetypes = { "netrw", "toggleterm" },

    modifiers = {
      ---Filename modifiers applied to dirname.
      ---See: `:help filename-modifiers`
      ---@type string
      dirname = ":~:.",

      ---Filename modifiers applied to basename.
      ---See: `:help filename-modifiers`
      ---@type string
      basename = "",
    },

    ---Whether to display path to file.
    ---@type boolean
    show_dirname = true,

    ---Whether to display file name.
    ---@type boolean
    show_basename = true,

    ---Whether to replace file icon with the modified symbol when buffer is
    ---modified.
    ---@type boolean
    show_modified = false,

    ---Get modified status of file.
    ---NOTE: This can be used to get file modified status from SCM (e.g. git)
    ---
    ---@type fun(bufnr: number): boolean
    modified = function(bufnr)
      return vim.bo[bufnr].modified
    end,

    ---Whether to show/use navic in the winbar.
    ---@type boolean
    show_navic = true,

    ---Get leading custom section contents.
    ---
    ---NOTE: This function shouldn't do any expensive actions as it is run on each render.
    ---
    ---@type fun(bufnr: number, winnr: number): barbecue.Config.custom_section
    lead_custom_section = function()
      return " "
    end,

    ---@alias barbecue.Config.custom_section
    ---|string # Literal string.
    ---|{ [1]: string, [2]: string? }[] # List-like table of `[text, highlight?]` tuples in which `highlight` is optional.
    ---
    ---Get custom section contents.
    ---
    ---NOTE: This function shouldn't do any expensive actions as it is run on each render.
    ---
    ---@type fun(bufnr: number, winnr: number): barbecue.Config.custom_section
    custom_section = function()
      return " "
    end,

    ---@alias barbecue.Config.theme
    ---|'"auto"' # Use your current colorscheme's theme or generate a theme based on it.
    ---|string # Theme located under `barbecue.theme` module.
    ---|barbecue.Theme # Same as '"auto"' but override it with the given table.
    ---
    ---Theme to be used for generating highlight groups dynamically.
    ---@type barbecue.Config.theme
    theme = theme,

    ---Whether context text should follow its icon's color.
    ---@type boolean
    context_follow_icon_color = false,

    symbols = {
      ---Modification indicator.
      ---@type string
      modified = "●",

      ---Truncation indicator.
      ---@type string
      ellipsis = "…",

      ---Entry separator.
      ---@type string
      separator = "",
    },

    ---@alias barbecue.Config.kinds
    ---|false # Disable kind icons.
    ---|table<string, string> # Type to icon mapping.
    ---Icons for different context entry kinds.
    ---@type barbecue.Config.kinds
    kinds = {
      File = "",
      Module = "",
      Namespace = "",
      Package = "",
      Class = "",
      Method = "",
      Property = "",
      Field = "",
      Constructor = "",
      Enum = "",
      Interface = "",
      Function = "",
      Variable = "",
      Constant = "",
      String = "",
      Number = "",
      Boolean = "",
      Array = "",
      Object = "",
      Key = "",
      Null = "",
      EnumMember = "",
      Struct = "",
      Event = "",
      Operator = "",
      TypeParameter = "",
    },
  },
  -- hide barbecue globally
  -- require("barbecue.ui").toggle(false)

  -- show barbecue globally
  -- require("barbecue.ui").toggle(true)

  -- toggle barbecue globally
  -- require("barbecue.ui").toggle()
  -- navigate to the second entry
  -- require("barbecue.ui").navigate(2)

  -- navigate to the last entry
  -- require("barbecue.ui").navigate(-1)

  -- just like before but on the given window
  -- require("barbecue.ui").navigate(index, winnr)
}
